草庐IT

git 通过 cron 推送

全部标签

go - 为 golang 静态二进制文件构建、部署、推送 docker 镜像

我正在寻找解决简单配置问题的方法;它已经困扰我很长一段时间了。:)我在github上有一个golang项目,它为我提供了一个静态二进制文件,并使用了godeps。现在我想确保godepgoinstall...命令可以在gitclone和docker容器从本地新建的二进制文件构建之后运行。作为一个选项,用户应该能够将其推送到dockerhub或适用的私有(private)仓库。我正在考虑使用Makefile,但这似乎太复杂了(设置gopath,然后是godepbuild,动态修改Dockerfile以指向二进制文件所在的位置,然后是dockerbuild)。有更简单的方法吗?

go - 如何通过引用传递以便我可以在调用函数中修改它?

我怎样才能将某些东西传递给一个函数,使其可以修改并且可以在调用堆栈中看到?(换句话说如何传递指针或引用?)packagemainimport("os/exec""fmt")funcprocess(names*[]string){fmt.Print("Preprocess",names)names[1]="modified"}funcmain(){names:=[]string{"leto","paul","teg"}process(&names)fmt.Print("Postprocess",names)}Error:invalidoperation:names[0](type*[]s

go - conn.Read 在通过其他 go 例程关闭 conn 时进入无限循环

我的代码有点复杂,但简单来说,它有多个go例程,所有都调用不同的TCP服务器,并在流中出现可读消息时在for循环中读取输入。到目前为止,一切都很好。现在有另一个go例程来管理之前的一堆“客户端”并在用户需要时关闭它们。为此,我将每个“conn”与适当的goroutine客户端相关联并关闭它。我面临的问题是,只要我调用任何conn对象的close函数,其对应的Read函数就会进入无限循环,不断读取空字符串。我写了一个简单的代码,类似于我在多个go例程中处理连接的方式-https://play.golang.org/p/wq7zt9Kqz7长话短说简而言之,我有一个“类”,它代表一个远程服

go - 通过引用 holder 对象传递值

以下代码将Holder指定为interface类型。可以对Holder对象进行哪些更改,以便它接收具有引用类型的任何类型,因此如果对值对象进行任何更改,它会反射(reflect)在main上。typeHolderstruct{Bodyinterface{}}typeValuestruct{InputintResultint}funcmain(){value:=Value{Input:5}holder:=Holder{Body:value}fmt.Println(value)//{50}modify(holder)fmt.Println(value)//{50}shoulddisplay

oop - 通过golang中的接口(interface)模拟功能

我正在尝试编写一个单元测试代码形式,其代码具有如下3级函数调用:主函数调用函数A(),然后函数A根据某些条件调用函数B()和C(),函数B调用函数E()和F(),而函数C调用函数G()和H()在某些条件下。上面就像我开发的代码,这里我想为函数B模拟函数E()和F(),为函数C模拟G()和H()。请建议我如何使用接口(interface)来实现。 最佳答案 Abstractfunctiontype您可以通过依赖注入(inject)而不是使用接口(interface)来做到这一点:import("fmt""math")typeafunc

windows - 通过在 Go 中调用 Windows DLL 发送 ARP 请求不起作用

我正在尝试调用WindowsAPISendARP从Go在Windows上发送arp请求,但它总是返回1168,又名ERROR_NOT_FOUND,MSDN对此错误代码的描述:Elementnotfound.ThiserrorisreturnedonWindowsVistaifthetheSrcIpparameterdoesnotspecifyasourceIPv4addressonaninterfaceonthelocalcomputerortheINADDR_ANYIPaddress(anIPv4addressof0.0.0.0).但我在Windows7上,而且我确实指定了正确的源I

go - 如何通过 Golang 中的短变量声明将返回值分配给函数输入?

考虑以下代码片段...f,err:=os.OpenFile(".",os.O_RDONLY,0666)为了检查错误并继续,我们需要有类似的东西..funccheckerr(errerror){iferr!=nil{panic(err)}}然后调用这个小函数来验证错误。例如..f,err:=os.OpenFile(".",os.O_RDONLY,0666)checkerr(err)files,err:=f.Readdirnames(0)checkerr(err)虽然这可行,但我正在寻找一种在初始化阶段本身直接调用checkerr()的快捷方式。见下文...f,checkerr(err):

rest - 通过测试用例,同时给出 500 作为响应

request,err:=http.NewRequest("GET",path,nil)response:=httptest.NewRecorder()r.ServeHTTP(response,request)varrawmap[string]map[string]string_=json.Unmarshal(response.Body.Bytes(),&raw)details:=raw["response"]我有一个TestFunction,我在其中使用了这段代码。是代码测试GET请求的RESTAPI。在我的第一个测试用例中,我命中了一个定义的处理程序,而在第二个测试用例中,我命中了

go - 在 Go 中测试通过 json http 响应返回的错误

我目前正在使用Go开发一个图像处理程序,它旨在拒绝上传不受支持的文件。我的意图是让Go程序通过服务器http.ResponceWritter返回错误,详细说明拒绝的情况,作为json,供上传服务使用。如何在服务器代码中设置错误:typeErrorstruct{ImgHandlerError`json:"error"`}typeImgHandlerErrorstruct{Messagestring`json:"message"`Codestring`json:"code"`}funcMakeError(message,codestring)*Error{errorMessage:=&Er

go - 调用 `go get` 时缺少 Git 命令

我的DockerfileFROMgolang:1.10.2-alpine3.7ASbuildRUNapk--no-cacheaddgccg++makeca-certificatesRUNapkaddgitWORKDIR/go/src/github.com/meowerCOPYGopkg.lockGopkg.toml./COPYutilutilCOPYeventeventCOPYdbdbCOPYsearchsearchCOPYschemaschemaCOPYmeow-servicemeow-serviceCOPYquery-servicequery-serviceCOPYpusher-s